package com.wskj.system.mapper;

import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.wskj.common.core.domain.entity.SysUser;
import com.wskj.common.core.mybatisplus.core.BaseMapperPlus;
import com.wskj.workbench.bo.app.AppSysUserQueryBo;
import com.wskj.workbench.vo.app.AppTeamVo;
import com.wskj.workbench.vo.web.TbDateCountVo;
import org.apache.ibatis.annotations.Param;

import java.math.BigDecimal;
import java.util.List;

/**
 * 用户表 数据层
 *
 * @author ruoyi
 */
public interface SysUserMapper extends BaseMapperPlus<SysUser> {

    Page<SysUser> selectPageUserList(@Param("page") Page<SysUser> page, @Param("user") SysUser user);

    /**
     * 根据条件分页查询用户列表
     *
     * @param sysUser 用户信息
     * @return 用户信息集合信息
     */
    List<SysUser> selectUserList(SysUser sysUser);

    /**
     * 根据条件分页查询未已配用户角色列表
     *
     * @param user 用户信息
     * @return 用户信息集合信息
     */
    Page<SysUser> selectAllocatedList(@Param("page") Page<SysUser> page, @Param("user") SysUser user);

    /**
     * 根据条件分页查询未分配用户角色列表
     *
     * @param user 用户信息
     * @return 用户信息集合信息
     */
    Page<SysUser> selectUnallocatedList(@Param("page") Page<SysUser> page, @Param("user") SysUser user);

    /**
     * 通过用户名查询用户
     *
     * @param userName 用户名
     * @return 用户对象信息
     */
    SysUser selectUserByUserName(String userName);

    /**
     * 通过用户ID查询用户
     *
     * @param userId 用户ID
     * @return 用户对象信息
     */
    SysUser selectUserById(Long userId);

    /**
     * 增加积分
     *
     * @param userId
     * @return
     */
    int addIntegralByUserId(@Param("userId") Long userId, @Param("integral") BigDecimal integral);

    /**
     * 兑换消费积分
     *
     * @param userId
     * @return
     */
    int reduceIntegralByUserId(@Param("userId") Long userId, @Param("integral") BigDecimal integral);

    /**
     * 提现余额-减去提现金额
     *
     * @param userId  提现人
     * @param balance 额度
     * @return
     */
    int reduceBalanceByUserId(@Param("userId") Long userId, @Param("balance") BigDecimal balance);

    /**
     * 提现失败-退回余额
     *
     * @param userId  提现人
     * @param balance 额度
     * @return
     */
    int increaseBalanceByUserId(@Param("userId") Long userId, @Param("balance") BigDecimal balance);


    Page<SysUser> selectPageNotSysUserList(@Param("page") Page<SysUser> page, @Param("user") SysUser user);

    /**
     * 通过用户名查询用户
     *
     * @param userName 用户名
     * @param userType 用户类型
     * @return 用户对象信息
     */
    SysUser selectUserByUserNameAndUserType(@Param("userName") String userName, @Param("userType") String userType);


    Page<AppTeamVo> getPageTeam(@Param("page") Page<AppSysUserQueryBo> page, @Param("bo") AppSysUserQueryBo bo,
                                @Param("inviteFullCode") String inviteFullCode, @Param("userId") Long userId);


    List<TbDateCountVo> last7Days(String userType);
}
